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Abstract 

We consider online algorithms for pull-based broadcast scheduling. In this setting there are n pages 
of information at a server and requests for pages arrive online. When the server serves (broadcasts) 
a page p, all outstanding requests for that page are satisfied. We study two related metrics, namely 
maximum response time (waiting time) and maximum delay-factor and their weighted versions. We 
obtain the following results in the worst-case online competitive model. 

• We show that FIFO (first-in first-out) is 2-competitive even when the page sizes are different. 
Previously this was known only for unit-sized pages |10| via a delicate argument. Our proof 
differs from IIOJ and is perhaps more intuitive. 

• We give an online algorithm for maximum delay-factor that is 0(l/e^)-competitive with (1 + e)- 
speed for unit-sized pages and with (2 + e)-speed for different sized pages. This improves on the 
algorithm in 1 12 1 which required (2 + e)-speed and (4 + e)-speed respectively. In addition we show 
that the algorithm and analysis can be extended to obtain the same results for maximum weighted 
response time and delay factor 

• We show that a natural greedy algorithm modeled after LWF (Longest- Wait-First) is not 0(1)- 
competitive for maximum delay factor with any constant speed even in the setting of standard 
scheduling with unit-sized jobs. This complements our upper bound and demonstrates the impor- 
tance of the tradeoff made in our algorithm. 
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1 Introduction 



We consider online algorithms in pull-based broadcasting. In this model there are n pages (representing 
some form of useful information) available at a server and clients request a page that they are interested 
in. When the server transmits a page p, all outstanding requests for that page p are satisfied since it is 
assumed that all clients can simultaneously receive the information. It is in this respect that broadcast 
scheduling differs crucially from standard scheduling where each jobs needs its own service from the server. 
We distinguish two cases: all the pages are of same size (unit-size without loss of generality) and when 
the pages can be of different size. Broadcast scheduling is motivated by several applications in wireless 
and LAN based systems |[Tl|2l|26l. It has seen a substantial interest in the algorithmic scheduling literature 
starting with the work of Bartal and Muthukrishanan [5|; see [21J. In addition to the applications, broadcast 
scheduling has sustained interest due to the significant technical challenges that basic problems in this setting 
have posed for algorithm design and analysis. To distinguish broadcast scheduling from "standard" job 
scheduling, we refer to the latter as unicast scheduling — we use requests in the context of broadcast and 
jobs in the context of unicast scheduling. 

In this paper, we focus on scheduling to minimize two related objectives: the maximum response time 
and the maximum delay factor. We also consider their weighted versions. Interestingly, the maximum re- 
sponse time metric was studied in the (short) paper of Bartal and Muthukrishnan |5 1 where they claimed that 
the online algorithm FIFO (for First In First Out) is 2-competitive for broadcast scheduling, and moreover 
that no deterministic online algorithm is (2 — e) -competitive. (It is easy to see that FIFO is optimal in unicast 
scheduling). Despite the claim, no proof was published. It is only recently, almost a decade later, that Chang 
et al. 1 10] gave formal proofs for these claims for unit-sizes pages. This simple problem illustrates the diffi- 
culty of broadcast scheduling: the ability to satisfy multiple requests for a page p with a single transmission 
makes it difficult to relate the total "work" that the online algorithm and the offline adversary do. The upper 
bound proof for FIFO in ifTOl is short but delicate. In fact, IH claimed 2-competitiveness for FIFO even 
when pages have different sizes. As noted in previous work HI [141 |25l, when pages have different sizes, 
one needs to carefully define how a request for a page p gets satisfied if it arrives midway during the trans- 
mission of the page. In this paper we consider the sequential model |[T4l . the most restrictive one, in which 
the server broadcasts each page sequentially and a client receives the page sequentially without buffering; 
see f^Sl on the relationship between different models. The claim in [5] regarding FIFO for different pages 
is in a less restrictive model in which clients can buffer and take advantage of partial transmissions and the 
server is allowed to preempt. The FIFO analysis in ifTOl for unit-sized pages does not appear to generalize 
for different page sizes. Our first contribution in this paper is the following. 

Theorem 1.1. FIFO is 2-competitive forminimizing maximum response time in broadcast scheduling even 
with different page sizes. 

Note that FIFO, whenever the server is free, picks the page p with the earliest request and non-preemptively 
broadcasts it. Our bound matches the lower bound shown even for unit-sized pages, thus closing one aspect 
of the problem. Our proof differs from that of Chang et al.; it does not explicitly use the unit-size assumption 
and this is what enables the generalization to different page sizes. The analysis is inspired by our previous 
work on maximum delay factor |[T2ll which we discuss next. 

Maximum (Weighted) Delay Factor and Weighted Response Time: The delay factor of a schedule is a 
metric recently introduced in 1 10| (and implicitly in |7 |) when requests have deadlines. Delay factor captures 
how much a request is delayed compared to its deadline. More formally, let Jp j denote the i'th request of 
page p. Each request Jp j arrives at Up^i and has a deadline dp j. The finish time /p j of a request Jp^i is defined 
to be the earliest time after Cp^j when the page p is sequentially transmitted by the scheduler starting from the 
beginning of the page. Note that multiple requests for the same page can have the same finish time. Formally, 
the delay factor of the job Jp j is defined as max{l, ^"^3^}; we refer to the quantity Sp^i = dp^i — Up^i 
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as the slack of Jp j. For a more detailed motivation of delay factor, see (12). Note that for unit-sized pages, 
delay factor generalizes response time since one could set dp j = Op^j + 1 for each request Jp j in which 
case its delay factor equals its response time. In this paper we are interested in online algorithms that 
minimize the maximum delay factor, in other words the objective function is min maxp 
also consider a related metric, namely weighted response time. Let Wp^i be a non-negative weight associated 
with Jp/, the weighted response time is then Wp^i{fp^i — ap^i) and the goal is to minimize the maximum 
weighted response time. Delay factor and weighted response time have syntactic similarity if we ignore the 
1 term in the definition of delay factor — one can think of the weight as the inverse of the slack. Although 
the metrics are some what similar we note that there is no direct way to reduce one to the other. On the other 
hand, we observe that upper bounds for one appear to translate to the other. We also consider the problem 
of minimizing the maximum weighted delay factor minmaxp j ifp ,{1, }. 

Surprisingly, the maximum weighted response time metric appears to not have been studied formally 
even in classical unicast scheduling; however a special case, namely maximum stretch has received attention. 
The stretch of a job is its response time divided by its processing time; essentially the weight of a job is the 
inverse of its processing time. Bender et al. ||6l [H, motivated by applications to web-server scheduling, 
studied maximum stretch and showed very strong lower bounds in the online setting. Using similar ideas, in 
some previous work |[T2l . we showed strong lower bounds for minimizing maximum delay factor even for 
unit-time jobs. In |[T2l . constant competitive algorithms were given for minimizing maximum delay factor in 
both unicast and broadcast scheduling; the algorithms are based on resource augmentation [20] wherein the 
algorithm is given a speed s > 1 server while the offline adversary is given a speed 1 server. They showed 
that SSF (shortest slack first) is 0(l/e)-competitive with (1 + e)-speed in unicast scheduling. SSF does not 
work well in the broadcast scheduling. A different algorithm that involves waiting, SSF-W (shortest slack 
first with waiting) was developed and analyzed in [12]; the algorithm is 0(l/e^) -competitive for unit-size 
pages with (2 + e)-speed and with (4 + e)-speed for different sized pages. In this paper we obtain improved 
results by altering the analysis of SSF-W in a subtle and important way. In addition we show that the 
algorithm and analysis can be altered in an easy fashion to obtain the same bounds for weighted response 
time and delay factor. 

Theorem 1.2. There is an algorithm that is (1 + e)-speed 0{l/e^)-competitive for minimizing maximum 
delay factor in broadcast scheduling with unit-sized pages. For different sized pages there is a (2 + e)-speed 
0(1/ e^) -competitive algorithm. The same bounds apply for minimizing maximum weighted response time 
and maximum weighted delay factor. 

Remark 1.3. Minimizing maximum delay factor is NP-hard and there is no (2 — e) -approximation unless 
P = NP for any e > in the offline setting for unit-sized pages. There is a polynomial time computable 
2-speed schedule with the optimal delay factor (with 1-speed) HiOV . Theo rem \1.2\ sives a polynomial time 
computable (1 + e)-speed schedule that is 0{l/e^) -optimal (with 1-speed). 

We remark that the algorithm SSF-W makes an interesting tradeoff between two competing metrics and 
we explain this tradeoff in the context of weighted response time and a lower bound we prove in this paper 
for a simple greedy algorithm. Recall that FIFO is 2-competitive for maximum response time in broadcast 
scheduling and is optimal for job scheduling. What are natural ways to generalize FIFO to delay factor 
and weighted response time? As shown in llT2l . SSF (which is equivalent to maximum weight first for 
weighted response time) is 0(l/e)-competitive with (1 + e)-speed for job scheduling but is not competitive 
for broadcast scheduling — it may end up doing much more work than necessary by transmitting a page 
repeatedly instead of waiting and accumulating requests for a page. One natural algorithm that extends 
FIFO for delay factor or weighted response time is to schedule the request in the queue that has the largest 
current delay factor (or weighted wait time). This greedy algorithm was labeled LF (longest first) since it 
can be seen as an extension of the well-studied LWF (longest-wait-first) for average flow time. Since LWF 
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is known to be 0(l)-competitive with 0(l)-speed for average flow time, it was suggested in ifTTl that LF 
may be 0(l)-speed 0(l)-competitive for maximum delay factor. We show that this is not the case even for 
unicast scheduling. 

Theorem 1.4. For any constants s,c > 1, LF is not c-competitive with s-speed for minimizing maximum 
delay factor (or weighted response time) in unicast scheduling of unit-time jobs. 

Our algorithm SSF-W can be viewed as an interesting tradeoff between SSF and LF. SSF gives pref- 
erence to small slack requests while the LF strategy helps avoid doing too much extra work in broadcast 
scheduling by giving preference to pages that have waited sufficiently long even if they have large slack. 
The algorithm SSF-W considers all requests whose delay factor at time t (or weighted wait time) is within a 
constant factor of the largest delay factor at t and amongst those requests schedules the one with the smallest 
slack. This algorithmic principle may be of interest in other settings and is worth exploring in the future. 

Other Related Work: We have focussed on maximum response time and its variants and have already 
discussed closely related work. Other metrics that have received substantial attention in broadcast scheduling 
are minimizing average flow time and maximizing throughput of satisfied requests when requests have 
deadlines. We refer the reader to a comprehensive survey on online scheduling algorithms by Pruhs, Sgall 
and Torng [24J (see also [23 1). The recent paper of Chang et al. [10] addresses, among other things, the 
offline complexity of several basic problems in broadcast scheduling. Average flow-time received substantial 
attention in both the offline and online settings 11211 IT7l[T8llT9l [3ll4l. For average flow time, there are three 
0(l)-speed 0(l)-competitive online algorithms. LWF is one of them |[T4l[TTIl and the others are BEQUI 
||T4l| and its extention |16|. Our recent work [11] has investigated L;^. norms of flow-time and showed that 
LWF is 0(A;)-speed 0( A;) -competitive algorithm. Constant competitive online algorithms for maximizing 
throughput for unit-sized pages can be found in ll22l l9l l27l[T3l . A more thorough description of related work 
is deferred to a full version of the paper. 

Organization: We prove each of the theorems mentioned above in a different section. The algorithm and 
analysis for weighted response time and weighted delay factor are very similar to that for delay factor and 
hence, in this version, we omit the analysis and only describe the algorithm. 

Notation: We denote the length of page p by Ip. That is, ip is the amount of time a 1-speed server takes to 
broadcast page p non-preemptively. We assume without loss of generality that for any request Jp j, Sp^i > Ip. 
For an algorithm A we let denote the maximum delay factor witnessed by A for a given sequence of 
requests. We let a* denote the optimal delay factor of an offline schedule. Likewise, we let denote the 
maximum response time witnessed by A and p* the optimal response time of an offline schedule. For a time 
interval / = [a, 5] we define |/| = 6 — a to be the length of interval /. 

2 Minimizing the Maximum Response Time 

In this section we analyze FIFO for minimizing maximum response time when page sizes are different. We 
first describe the algorithm FIFO. FIFO broadcasts pages non-preemptively. Consider a time t when FIFO 
finished broadcasting a page. Let Jp j be the request in FIFO's queue with earliest arrival time breaking 
ties arbitrarily. FIFO begins broadcasting page p at time t. At any time during this broadcast, we will say 
that Jp j forced FIFO to broadcast page p at this time. When broadcasting a page p all requests for page p 
that arrived before the start of the broadcast are simultaneously satisfied when the broadcast completes. Any 
request for page p that arrive during the broadcast are not satisfied until the next full transmission of p. 

We consider FIFO when given a 1-speed machine. Let a be an arbitrary sequence of requests. Let OPT 
denote some fixed offline optimum schedule and let p* denote the optimum maximum response time. We 
will show that p^^^^ < 2p* . For the sake of contradiction, assume that FIFO witnesses a response time 
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cp* by some job Jg ^ for some c > 2. Let t* be the time Jg ^ is satisfied, that is t* = fq^k- Let ti be the 
smallest time less than t* such that at any time t during the interval [ti , t*] the request which forces FIFO 
to broadcast a page at time t has response time at least p* when satisfied. Throughout the rest of this section 
we let I = [ti, t*]. Let Ji denote the requests which forced FIFO to broadcast during /. Notice that during 
the interval /, all requests in Jj are completely satisfied during this interval. In other words, any request in 
Jj starts being satisfied during / and is finished during /. 

We say that OPT merges two distinct requests for a page p if they are satisfied by the same broadcast. 

Lemma 2.1. OPT cannot merge any two requests in Ji into a single broadcast. 

Proof. Let Jp j, Jpj € J/ such that i < j. Note that that Jp j is satisfied before Jpj. Let t' be the time 
that FIFO starts satisfying request Jp j. By the definition of /, request Jp j has response time at least p*. 
The request Jp j must arrive after time t', that is apj > t' , otherwise request Jp j is satisfied by the same 
broadcast of page p that satisfied Jp^j. Therefore, it follows that if OPT merges Jp j and Jp j then the finish 
time of Jp j in OPT is strictly greater than its finish time in FIFO which is already at least p*; this is a 
contradiction to the definition of p*. □ 

Lemma 2.2. All requests in Ji arrived no earlier than time t\ — p*. 

Proof. For the sake of contradiction, suppose some request Jp j G Ji arrived at time Op^j < ti — p*. 
During the interval [op^j + p*,ti] the request Jp^i must have wait time at least p*. However, then any request 
which forces FIFO to broadcast during [ap^i + p*,ti] must have response time at least p*, contradicting the 
definition of ti. □ 

We are now ready to prove Theorem ll.il stating that FIFO is 2-competitive. 

Proof. Recall that all requests in J} are completely satisfied during /. Thus we have that the total size of 
requests in J'j is By definition Jg^j^ witnesses a response time greater than 2p* and therefore t* — aq^k > 
2/9*. Since J^ ^ G J'j is the last request done by FIFO during I, all requests in J7/ must arrive no later than 
fc. Therefore, these requests must be finished by time Og ^ + p* by the optimal solution. From Lemma l2!2l 
all the requests J'j arrived no earlier than ti — p*. Thus OPT must finish all requests in J'j, whose total 
volume is |J|, during lopt = [h — p*,aq^k + P*]- Thus it follows that [/| < — p*,aq^k + P*]|> which 
simplifies to t* < aq^^ + 2p*. This is a contradiction to the fact that t* — ^ > 2p*. □ 
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Figure 1 : Broadcasts by FIFO satisfying requests in Jj are shown in blue. Note that Uq^k and Uq^k + P* are 
not necessarily contained in /. 

We now discuss the differences between our proof of FIFO for varying sized pages and the proof given 
by Chang et al. in ifTOl showing that FIFO is 2-competitive for unit sized pages. In [10] it is shown that at 
anytime t, F{t), the set of unique pages in FIFO's queue satisfies the following property: \F{t) \ 0{t)\ < 
\0{t)\ where 0{t) is the set of unique pages in OPT's queue. This easily implies the desired bound. To 
establish this, they use a slot model in which unit-sized pages arrive only during integer times which allows 
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one to define unique pages. This may appear to be a technicality, however when considering different sized 
pages, it is not so clear how one even defines unique pages since this number varies during the transmission 
of p as requests accumulate. Our approach avoids this issue in a clean manner by not assuming a slot model 
or unit-sized pages. 

3 Minimizing Maximum Delay Factor and Weighted Response time 

In this section we consider the problem of minimizing maximum delay factor and prove Theorem 1 1.21 
3.1 Unit Sized Pages 

In this section we consider the problem of minimizing the maximum delay factor when all pages are of 
unit size. In this setting we assume preemption is not allowed. In the standard unicast scheduling setting 
where each broadcast satisfies exactly one request, it is known that the algorithm which always schedules the 
request with smallest slack at any time is (1 + e)-speed 0(-)-competitive [12]. However, in the broadcast 
setting this algorithm, along with other simple greedy algorithms, do not provide constant competitive ratios 
even with extra speed. The reason for this is that the adversary can force these algorithm to repeatedly 
broadcast the same page even though the adversary can satisfy each of these requests in a singe broadcast. 

Due to this, we consider a more sophisticated algorithm called SSF-W (Shortest-Slack-First with Wait- 
ing). This algorithm was developed and analyzed in [12]. In this paper we alter the algorithm in a slight but 
practically important way. The main contribution is, however, a new analysis that is at a high-level similar 
in outline to the one in |[T2l but is subtly different and leads to much improved bound on its performance. 
SSF-W adaptively forces requests to wait after their arrival before they are considered for scheduling. The 
algorithm is parameterized by a real value c > 1 which is used to determine how long a request should wait. 
Before scheduling a page at time t, the algorithm determines the largest current delay factor of any request 
that is unsatisfied at time t, at- Amongst the unsatisfied requests that have a current delay factor at least 
-at, the page corresponding to the request with smallest slack is broadcasted. Note that in the algorithm, 
each request is forced to wait to be scheduled until it has delay factor at least -at. Thus SSF-W can be seen 
an adaptation of the algorithm which schedules the request with smallest slack in broadcasting setting with 
explicit waiting. Waiting is used to potentially satisfy multiple requests with similar arrival times in a single 
broadcast. Another interpretation, that we mentioned earlier, is that SSF-W is a balance between LF and 
SSF. 



Algorithm: SSF-W 

• Let at be the maximum delay factor of any request in SSF-W's queue at time t. 

• At time t, let Q{t) = {Jp^i \ Jp^i has not been satisfied and > ^at}. 

• If the machine is free at t, schedule the request in Q{t) with the smallest slack non-preemptively. 

First we note the difference between SSF-W above and the one described in fT2]. Let a't denote the 
maximum delay factor witnessed so far by SSF-W at time t over all requests seen by t including satisfied 
and unsatisfied requests. In |[T2l . a request Jp j is in Q(t) if > Iq/^. Note that a't is monotonically 

increases with t while at can increase and decrease with t and is never more than a^. In the old algorithm it 
is possible that Q{t) is empty and no request is scheduled at t even though there are outstanding requests! 
Our new version of SSF-W can be seen as more practical since there will always be requests in Q{t) if 
there are outstanding requests and moreover it adapts and may reduce at as the request sequence changes 
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with time. It is important to note that our analysis and the analysis given in [12] hold for both definitions of 
SSF-W with some adjustments. 

We analyze SSF-W when it is given a (1 + e)-speed machine. Let c > 1 + | be the constant which 
parameterizes SSF-W. Let o be an arbitrary sequence of requests. We let OPT denote some fixed offline 
optimum schedule and let a* and a^^^''^ denote the maximum delay factor achieved by OPT and SSF-W, 
respectively. We will show that a^^^"^ < (?a* . For the sake of contradiction, suppose that SSF-W 
witnesses a delay factor greater than (?a* . We consider first time t* when SSF-W has some request 
in its queue with delay factor c^a*. Let the request ^ be a request which achieves the delay factor (?a* at 
time t* . Let t\ be the smallest time less than t* such that at each time t during the interval [ti, t*] if SSF-W 
is forced to broadcast by request Jp,j at time t it is the case that -f^ > a* and Sp,i < Sg^k- Throughout 
this section we let / = [ti, t*]. The main difference between the analysis in 112^ and the one here is in the 
definition of ti. In [12], ti was implicitly defined to be ^ + c{fg^k — Og,A,)- 

We let J'j denote the requests which forced SSF-W to schedule broadcasts during the interval 
We now show that any two request in J'j cannot be satisfied with a single broadcast by the optimal solution. 
Intuitively, the most effective way the adversary to performs better than SSF-W is to merge requests of the 
same page into a single broadcast. Here we will show this is not possible for the requests in J'j. We defer 
the proof of Lemma |3?T] to the Appendix, since the proof is similar to that of Lemma IZT] 

Lemma 3.1. OPT cannot merge any two requests in Jj into a single broadcast. 

To fully exploit the advantage of speed augmentation, we need to ensure that the length of the interval I 
is sufficiently long. 

Lemma 3.2. |/| = \[ti,t*\\ > (c^ - c)Sq^ka*. 

Proof. The request Jg ^ has delay factor at least ca* at any time during /' = [t' , t*], where t' = t* — (c^ — 
c)Sq^kCt*. Let T G /'. The largest delay factor any request can have at time r is less than c^a* by definition 
of t* being the first time SSF-W witnesses delay factor c^a*. Hence, Ur < c^a*. Thus, the request Jg ^ is in 
the queue Q{t) because ca* > -Ur. Moreover, this means that any request that forced SSF-W to broadcast 
during /', must have delay factor at least a* and since Jq_fc S Q{t) for any r S /', the requests scheduled 
during /' must have slack at most Sq^k- D 

We now explain a high level view of how we lead to a contradiction. From Lemma lTTl we know any two 
requests in Jj cannot be merged by OPT. Thus if we show that OPT must finish all these requests during 
an interval which is not long enough to include all of them, we can draw a contradiction. More precisely, we 
will show that all requests in Jj must be finished during lopt by OPT, where lopt = [ti — 2Sq^k(^*c, t*]. It 
is easy to see that all these requests already have delay factor a* by time t*, thus the optimal solution must 
finish them by time t*. For the starting point, we will bound the arrival times of the requests in Jj in the 
following lemma. After that, we will draw a contradiction in Lemma [l!4l 

Lemma 3.3. Any request in Jj must have arrived after time ti — 2Sq^kCt*c. 

Proof. For the sake of contradiction, suppose that some request Jp^i G Jj arrived at time t' < ti — 25^ fea*c. 
Recall that Jp j has a slack no bigger than Sq^k by the definition of /. Therefore at time ti — Sq^kO*c, Jp^i 
has a delay factor of at least ca*. Thus any request scheduled during the interval /' = [ti — Sq^ka*c, ti] has 
a delay factor no less than a* . We observe that Jp j is in Q{t) for r € /'; otherwise there must be a request 
with a delay factor bigger than c^a* at time r and this is a contradiction to the assumption that t* is the first 
time that SSF-W witnessed a delay factor of c^a* . Therefore any request scheduled during /' has a slack 
no bigger than Sp^i. Also we know that Sp^i < Sq^k- In sum, we showed that any request done during /' had 
slack no bigger than 5^ ^ and a delay factor no smaller than a*, which is a contradiction to the definition of 
ti. □ 
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Now we are ready to prove the competitiveness of SSF-W. 

Lemma 3.4. Suppose c is a constant s.t. c > 1 + 2/e. /fSSF-W has (1 + e)-speed then a^^^'"^ < c^a*. 

Proof. For the sake of contradiction, suppose that a^^^'^ > c^a*. During the interval /, the number of 
broadcasts which SSF-W transmits is (1 + e)|/|. From Lemma 1331 all the requests processed during / 
have arrived no earlier than ti — 2ca*Sq^k- We know that the optimal solution must process these requests 
before time t* because these requests have delay factor at least a* by t*. By Lemma [3TT] the optimal solution 
must make a unique broadcast for each of these requests. Thus, the optimal solution must finish all of these 
requests in 2ca*5g fc + |/| time steps. Thus, the it must hold that (1 + e)\I\ < 2ca*Sq^k + l-^l- Using 
Lemma [331 this simplifies to c < 1 + 2/e, which is a contradiction to c > 1 + 2/e,. □ 

The previous lemmas prove the first part of Theorem 11.21 when c = 1 + 3/e. Namely that SSF-W 
is a (1 + e)-speed 0(^)-competitive algorithm for minimizing the maximum delay factor in broadcast 
scheduling with unit sized pages. 

We now compare proof of Theorem 11.21 and the proof of Theorem 11.11 with the analysis given in [T2] . 
The central technique used in [12] and in our analysis is to draw a contradiction by showing that the optimal 
solution must complete more requests than possible on some time interval /. This technique is well known 
in unicast scheduling. At the heart of this technique is to find the which requests to consider and bounding 
the length of the interval /. This is where our proof and the one given in 1 12 1 differ. Here we are more 
careful on how / is defined and how we find requests the optimal solution must broadcast during /. This 
allows us to show tighter bounds on the speed and competitive ratios while simplifying the analysis. In fact, 
our analysis of FIFO and SSF-W shows the importance of these definitions. Our analysis of FIFO shows 
that a tight bound on the length of / can force a contradiction without allowing extra speed-up given to the 
algorithm. Our analysis of SSF-W shows that when the length of / varies how resource augmentation can 
be used to force the contradiction. 

3.2 Weighted Response Time and Weighed Delay Factor 

Before showing that SSF-W is (2 + e)-speed 0(^)-competitive for minimizing the maximum delay factor 
with different sized pages, we show the connection of our analysis of SSF-W to the problem of minimizing 
weighted response time. In this setting a request Jp^i has a weight Wp^i instead of a slack. The goal is to 
minimize the maximum weighted response time maxp j Wp^i{fp^i — ap^i). We develop an algorithm which we 
call BWF-W for Biggest- Wait-First with Waiting. This algorithm is defined analogously to the definition 
of SSF-W. The algorithm is parameterized by a constant c > 1. At any time t before broadcasting a page, 
BWF-W determines the largest weighted wait time of any request which has yet to be satisfied. Let this 
value be pt- The algorithm then chooses to broadcast a page corresponding to the request with largest weight 
amongst the requests whose current weighted wait time at time t is larger than -pt. 



Algorithm: BWF-W 

• Let Pt be the maximum weighted wait time of any request in BWF-W's queue at time t. 

• At time t, let Q{t) = {Jp^i \ Jp^i has not been satisfied and Wp^i{t — ap.i) > ^pt}- 

• If the machine is free at t, schedule the request in Q{t) with largest weight non-preemptively. 

Although minimizing the maximum delay factor and minimizing the maximum weighted flow time are 
very similar metrics, the problems are not equivalent. 
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It may also be of interest to minimize the maximum weighted delay factor. In this setting each request 
has a deadline and a weight. The goal is to minimize m.aXp iWp^i{fp^i — ap^i)/Sp^i. For this setting we 
develop another algorithm which we call SRF-W (Smallest-Ratio-First with Waiting). The algorithm takes 
the parameter c. At any time t before broadcasting a page, SRF-W determines the largest weighted delay 
factor of any request which has yet to be satisfied. Let this value be af. The algorithm then chooses to 
broadcast a page corresponding to the request with the smallest ratio of the slack over the weight amongst 
the requests whose current weighted delay factor at time t is larger than ^af. The algorithm can be formally 
expressed as follows. 



Algorithm: SRF-W 

• Let af be the maximum weighted delay factor of any request in SRF-W's queue at time t. 

• At time t, let Q{t) = {Jp^i \ Jp^i has not been satisfied and Wp^i{t — ap^i)/Sp^i > ^.af}. 

• If the machine is free at t, schedule the request in Q(t) with smallest slack over weight non- 
preemptively. 

For the problems of minimizing the maximum weighted response time and weighted delay factor, the 
upper bounds shown for SSF-W in this paper also hold for BWF-W and SRF-W, respectively. The analysis 
of BWF-W and SRF-W is very similar to that of SSF-W and the proofs are omitted. 

3.3 Varying Sized Pages 

Here we extend our ideas to the case where pages can have a different sizes for the objective of minimizing 
the maximum delay factor. We develop a generalization of SSF-W for this setting which is similar to the 
generalization of SSF-W given in 1 12 1. For each page p, we let £p denote the length of page p. Since pages 
have different lengths, we allow preemption. Therefore, if ti is the time where the broadcast of page p is 
started and t2 is the time that this broadcast is completed it is the case that Ip < t2 — ti. K request for the 
page p is satisfied by this broadcast only if the request arrives before time ti. A request that arrives during 
the interval (ti, does not start being satisfied because it must receive a sequential transmission of page p 
starting from the beginning. It is possible that a transmission of page p is restarted due to another request 
for page p arriving which has smaller slack. The original transmission of page p in this case is abandoned. 
Notice that this results in wasted work by the algorithm. It is because of this wasted work that more speed 
is needed to show the competitiveness of SSF-W. 

We outline the details of modifications to SSF-W. As before, at any time t, the algorithm maintains 
a queue Q{t) at each time where a request Jp j is in Q{t) if and only if > ^at- The algorithm 

broadcasts a request with the smallest slack in Q{t). The algorithm may preempt a broadcast of p that is 
forced by request Jp^i if another request Jpi j becomes available for scheduling such that Spij < Sp^i. If the 
request Jp i ever forces SSF-W to broadcast again, then SSF-W continues to broadcast page p from where 
it left off before the preemption. If another request for page p forces SSF-W to broadcast page p before 
Jp^i is satisfied, then the transmission of page p is restarted. A key difference between our generalization of 
SSF-W and the one from |[T2l is that in our new algorithm, requests can be forced out of Q even after they 
have been started. Hence, in our version of SSF-W every request in Q{t) has current delay factor at least 
-at at time t. Our algorithm breaks ties arbitrarily. In [12], ties are broken arbitrarily, but the algorithm 
ensures that if a request Jp ^ is started before a request Jp/ j then Jp ^ will be finished before request Jp'j. 
Here, this requirement is not needed. Note that the algorithm may preempt a request Jp^i by another request 
Jp^k, for the same page p if Sp^k < Sp^i. In this case the first broadcast of page p is abandoned. Notice that 
multiple broadcasts of page p can repeatedly be abandoned. 
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We now analyze the extended algorithm assuming that it has a (2 + e)-speed advantage over the op- 
timal offline algorithm. As mentioned before, the extra speed is needed to overcome the wasted work by 
abandoning broadcasts. 

As before, let a be an arbitrary sequence of requests. We let OPT denote some fixed offline optimum 
schedule and let a* denote the optimum delay factor. Let c > 1 + | be the constant that parameterizes 
SSF-W. We will show that a^^^'^ < c^a*. For the sake of contradiction, suppose that SSF-W witnesses 
a delay factor greater than c^a*. We consider the first time t* when SSF-W has some request in its queue 
with delay factor c^a*. Let the request Jg ^ be a request which achieves the delay factor c^a* at time t*. Let 
ti be the smallest time less than t* such that at each time t during the interval [ti, t*] if SSF-W is forced to 
broadcast by request Jp^i at time t it is the case that > a* and Sp^i < Sq^k- Throughout this section 

we let / = Notice that some requests that force SSF-W to broadcast during / could have started 

being satisfied before ti. 

We say that a request starts being scheduled at time t if it is the request which forces SSF-W to broadcast 
at time t and t is the first time the request forces SSF-W to schedule a page. Notice that a request can only 
start being satisfied once and at most one request starts being scheduled at any time. We now show a lemma 
analogous to Lemma [3?T] 

Lemma 3.5. Consider two distinct requests Jxj and Jx,ifor some page x. If Jx,j ond J^^i both start being 
scheduled by SSF-W during the interval I then OPT cannot satisfy J^j and Jx,i by a single broadcast. 

Proof. Without loss of generality say that request Jx^j was satisfied before request Jx^i by SSF-W. Let t' 
be the time that SSF-W starts satisfying request Jx^j. By the definition of /, request Jxj must have delay 
factor at least a* at this time. We also know that the request Jx^i must arrive after time t' , otherwise request 
Jx^i must also be satisfied at time t' . If the optimal solution combines these requests into a single broadcast 
then the request Jx^j must wait until the request Jx^i arrives to be satisfied. However, this means that the 
request Jx^j must achieve a delay factor greater than a* by OPT, a contradiction of the definition of a*. □ 

The next two lemmas have proofs similar to Lemma 13.21 and Lemma 13.31 we defer the proofs to the 
Appendix. 

Lemma 3.6. |/| = \[ti,t*]\ > (c^ - c)Sq^ka*. 

Lemma 3.7. Any request which forced SSF-W to schedule a page during I must have arrived after time 
ti - 2Sq^ka*c. 

Using the previous lemmas we can bound the competitiveness of SSF-W. In the following lemma the 
main difference between the proof for unit sized pages and the proof for varying sized pages can be seen. 
The issue is that there can be some requests which start being satisfied before time ti which force SSF-W 
to broadcast a page during the interval /. When these requests were started, their delay factor need not be 
bounded by a* . Due to this, it is possible for these requests to be merged with other requests which forced 
SSF-W to broadcast on the interval /. 

Lemma 3.8. Suppose c is a constant s.t. c > 1 + 4/e. If SSF-W has (2 + e)-speed then a^^^'^ < c^a*. 

Proof. For the sake of contradiction, suppose that a^^^'^ > c^a*. Let A be the set of requests which start 
being satisfied before time ti which force SSF-W to broadcast at some time during /. Notice that no two 
requests in A are for the same page. Let B be the set of requests which start being satisfied during the interval 
/. Note that the sets A and B may consist of requests whose corresponding broadcast was abandoned at 
some point and that ^ n S = by definition. Let Vj^ and Vg denote the total sum of size of the requests in 
A and B, respectively. 
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During the interval /, the volume of broadcasts which SSF-W transmits is (2 + e)|/|. Notice that 
V_a + Vb> (2 + e)|/|, since AU B accounts for all requests which forced SSF-W to broadcast their pages 
during /. From Lemma [3^ all the requests processed during / have arrived no earlier than ti — 2ca*Sq^k- 
We know that the optimal solution must process these requests before time t* because these requests have 
delay factor at least a* by this time. 

By Lemma |33] the optimal solution must make a unique broadcast for each request in B. We also know 
that no two requests in A can be merged because no two requests in A are for the same page. The optimal 
solution, however, could possibly merge requests in A with requests in B. Thus, the optimal solution must 
broadcast at least a maxjV^, Vg} volume of requests during the interval [ti — 2ca*5g fc,t*]. Notice that 
max{y4, Vb} > ^{Va + Vb) > ^(2 + e)|/| and that \[ti - 2ca* Sq^k,t*]\ = 2ca*Sq,k + Therefore, 
it must hold that i(2 + e)[/[ < 2ca*Sq^k + With Lemma [331 this simphfies to c < 1 + 4/e. This is a 
contradiction toc>l + 4/e. □ 

Thus, we have the second part of Theroem ll.2l by setting c = 1 + 5/e. Namely that SSF-W is (2 + e)- 
speed 0(^)-competitive for minimizing the maximum delay factor for different sized pages. 



4 Lower Bound for a Natural Greedy Algorithm LF 

In this section, we consider a natural algorithm which is similar to SSF-W. This algorithm, which we will 
call LF for Longest Delay First, always schedules the page which has the largest delay factor. Notice that 
LF is the same as SSF-W when c = 1. However, we are able to show a negative result on the algorithm for 
minimizing the maximum delay factor. This demonstrates the importance of the tradeoff between scheduling 
a request with smallest slack and forcing requests to wait. The algorithm LF was suggested and analyzed 
in our recent work 111] and is inspired by LWF which was shown to be 0(l)-competitive with 0(l)-speed 
for average flow time lITSll . In lITTI LF is shown to be 0(A;) -competitive with 0(A;)-speed for norms of 
flow time and delay factor in broadcast scheduling for unit sized pages. Note that LF is a simple greedy 
algorithm. It was suggested in f\V\ that LF may be competitive for maximum delay factor which is the 
Loo -norm of delay factor. 

To show the lower bound on the LF, we will show that it is not 0(l)-speed 0(l)-competitive, even in 
the standard unicast scheduling setting with unit sized jobs. Since we are considering the unicast setting 
where processing a page satisfies exactly one request, we drop the terminology of 'requests' and use 'jobs'. 
We also drop the index of a request Jp j and use Jj since there can only be one request for each page. Let us 
say that Jj has a wait ratio of rj(t) = at time t > Ui, where Oj and Si is the arrival time and slack size 
of Jj. Note that the delay factor of Jj is max(l, rj(/j)) where fi is Jj's finish time. We now formally define 
LF. The algorithm LF schedules the request with the largest wait ratio at each time. LF can be seen as a 
natural generalization of FIFO. This is because FIFO schedules the request with largest wait time at each 
time. Recall that SSF-W forces requests to wait to help merge potential requests in a single broadcast. The 
algorithm LF behaves similarly since it implicitly delays each request until it is the request with the largest 
wait ratio, potentially merging many requests into a single broadcast. Hence, this algorithm is a natural 
candidate for the problem of minimizing the maximum delay factor and it does not need any parameters like 
the algorithm SSF-W. However, this algorithm cannot have a constant competitive ratio with any constant 
speed. 

For any speed-up s > 1 and any constant c > 2, we construct the following adversarial instance a. For 
this problem instance we will show that LF has wait ratio at least c, while OPT has wait ratio at most 1. 
Hence, we can force LF to have a competitive ratio of c, for any constant c > 2. In the instance a, there 
are a series job groups J7i for < « < k, where A; is a constant to be fixed later. We now fix the jobs in 
each group. For simplicity of notation and readability, we will allow jobs to arrive at negative times. We can 
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simply shift each of the times later, so that all arrival times are positive. It is also assumed that s and c are 
integers in our example. 

All jobs in each group J7i have the same arrival time Ai = —{sc)^~^~^^ — Yl'j=o^^ i^^V ^^'^ have the 

same slack size of Si = (^I'^^'yl^^k-i ■ There will be s(sc)'^+^ jobs in the group Jo and s(sc)'^^* jobs in the 
group for 1 < i < k. 

We now explain how LF and OPT behave for the instance a. For simplicity, we will refer to J'i, instead 
of a job in J'i, since all jobs in the same group are indistinguishable to the schedular. For the first group 

LF starts and keeps processing Jq upon its arrival until completing it. On the other hand, we let OPT 
procrastinate Jq until OPT finishes all jobs in J7i to Jk- This does not hurt OPT, since the slack size of 
the jobs in Jq is so large. In fact, we will show that OPT can finish Jq by its deadline. For each group J 
for I < i < k, OPT will start J upon its arrival and complete each job in J without interruption. To the 
contrary, for each I < i < k LF will not begin scheduling J until the jobs have been substantially delayed. 
The delay of Jk is critical for LF, since the slack of Jk is small. For intuitive understanding, we refer the 
reader to Figure 2. 

LF 

1 * * I •Jk-2 

Fk-2 

OPT LF 

I * n 1 * * I Sfk—i 

Ak-i -Ffc-i 

OPT LF 
I * * r**i JTfe 

Ak Fk 




Wait Ratio 



Time 

Figure 2: Comparison of scheduling of group Jk, Jk-i, and Jk-2 by LF and OPT. 

We now formally prove that LF achieves wait ratio c, while OPT has wait ratio at most 1 for the given 
problem instance a. Let Fi = Ai + (sc)'^"*'*'^, < i < k. Let Ri be the maximum wait ratio for any job in 
Ji witnessed by LF. We now define to be a constant such that (1 — ^)'^c < ^. 

Lemma 4.1. LF, given speed s, processes Jq during [Aq, Fq] and Ji during [-Fj_i, Fi], 1 < i < k. 

Proof Sketch: By simple algebra one can check that the length of the time intervals [Aq, Fq] and Fi] 
is the exact amount of time for LF with s-speed needs to completely process Jq and Ji, respectively. 

First we show that Jq is finished during [Aq, Fq] by LF. It can be seen that at time Fq the jobs in Jj for 
'2' < j < k have not arrived, so we can focus on the class Ji. The jobs in Ji can be shown to have the same 
wait ratio as the jobs in Jq at time Fq and therefore the jobs in Ji have smaller wait ratio than the jobs in 
Jo at all times before Fq. This is because Jq has a bigger slack than Ji. Hence, LF will finish all of the 
jobs in Jq before beginning the jobs in Ji. 

To complete the proof, we show that Ji is finished during Fj] by LF. It can be seen that at time 

Fi the jobs in Jj for i + 2 < j < k have not arrived, so we can focus on the class Ji+i. The jobs in Ji 
can be shown to have the same wait ratio as the jobs in Ji+i at time Fi and therefore the jobs in Ji+i have 
smaller wait ratio than the jobs in Ji at all times before Fi. Hence, LF will finish all of the jobs in Ji before 
beginning the jobs in Ji+i. 

□ 
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Using Lemma |4TT] and the given arrival times of each of the jobs we have the following lemma. 

Lemma 4.2. Ri = c(l - i)''"* for < i < k. 

Notice that Lemma |4!2] implies that Rk > c. Hence, the maximum delay factor witnessed by LF is at 
least c. In the following lemma, we show that there exists a valid scheduling by OPT where the maximum 
wait ratio is at most one. This will show that LF achieves a competitive ratio of c. Note that Lemma 14.21 
shows that Rq < j^- 

Lemma 4.3. Consider a schedule which processes each job in during [Fk,Fj. + \Jq\\ and each job in 
Ji during [Ai,Ai + \J'i\\for 1 < i < k. This schedule is valid and, moreover, the maximum wait ratio 
witnessed by this schedule is at most one. 

Proof Sketch: It is not hard to show that the time intervals [F^, Fjt + |^ol] and [Ai, Ai + \Ji\] for \ < i < k 
do not overlap, therefore this is a valid schedule. 

The wait ratio witnessed by the jobs in groups for 1 < i < A; can easily be seen to be at most 1. This 
is because this schedule processes each of these jobs as soon as they arrive. We now show that the wait ratio 
of each of the jobs in Jq is at most 1. Recall that i?o, the maximum wait ratio of Jq by LF is at most ^ at 
time Fq. Using the fact sc > 2, we can easily show that — tIqI ^ 2|i<o — ylol- Note that OPT can finish 
Jq during [Fk,Fk + s\Fq — Aq\], since LF with s-speed could finish Jq during [Aq, Fq\. Thus the wait ratio 
of Jo at time Fk + s\Fo - Ao| is at most ^ < 1. □ 

From Lemma 14.21 the maximum delay factor witnessed by LF is c and by Lemma 14.31 the maximum 
delay factor witnessed by OPT is 1. Hence we have the proof of Theorem 1 1.41 

5 Conclusion 

In this paper, we showed an almost fully scalable algorithrrQ for minimizing the maximum delay factor in 
broadcasting for unit sized jobs. The slight modification we make to SSF-W from |[T2l makes the algorithm 
more practical. Using the intuition developed for the maximum delay factor, we proved that FIFO is in fact 
2-competitive for varying sized jobs closing the problem for minimizing the maximum response time online 
in broadcast scheduling. 

We close this paper with the following open problems. Although the new algorithm for the maximum 
delay factor with unit sized jobs is almost fully scalable, it explicitly depends on speed given to the algorithm. 
Can one get another algorithm independent of this dependency? For different sized pages, it is still open 
on whether there exists a (1 + e)-speed algorithm that is 0(l)-competitive. For minimizing the maximum 
response time offline it is of theoretical interest to show a lower bound on the approximation ratio that can 
be achieved or to show an algorithm that is a c-approximation for some c < 2. 
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A Omitted Proofs 
A.l Proof of Lemma 13.11 

Proof. Let Jx^i, Jx,j S J^i such that i < j. Let t' be the time that SSF-W starts satisfying request j. By 
the definition of /, request Jx^i must have delay factor at least a* at time j. We also know that the request 
Jxj must arrive after time t', otherwise request J^j must also be satisfied at time t'. If the optimal solution 
combines these requests into a single broadcast then the request J^. j must wait until the request Jxj arrives 
to be satisfied. However, this means that the request Jx,i must achieve a delay factor greater than a* by 
OPT, a contradiction of the definition of a*. □ 

A.2 Proof of Lemma 13.61 

Proof. The request Jg ^ has delay factor at least ca* at any time t during I' = [t', t*], where t' = t* — (c^ — 
c)Sq^kC(*. The largest delay factor any request can have during /' is less than c^a* by definition of t* being 
the first time SSF-W witnesses delay factor c^a*. Hence the request Jg ^ is in the queue Q{t) at any time t 
during /'. Therefore, any request that forced SSF-W to broadcast on I', must have delay factor at least a* 
and since Jg ^ € Q{t) for all t G /', the requests scheduled on /' must have slack at most Sg^k- D 
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A.3 Proof of Lemma 13.71 



Proof. For the sake of contradiction, suppose that some request Jp i that forced SSF-W to broadcast page 
p on the interval / arrived at time t' < ti — 25g fca*c. Recall that Jp j has a slack no bigger than ^ by 
the definition of I. Therefore at time ti — Sq^kO*c, Jp^i has a delay factor of at least ca* . Thus any request 
scheduled during the interval [ti — Sq^kO*c, ti] has a delay factor no less than a*. We observe that Jp j is 
in Q{t) for t £ [ti — Sq^kO!*c, ti]; otherwise there must be a request with a delay factor bigger than c^a* 
at time r and this is a contradiction to the assumption that t* is the first time that SSF-W witnessed a delay 
factor of c^a*. Therefore any request that forced SSF-W to broadcast during [ti — Sq^kOi*c, ti] has a slack 
no bigger than Sp^,. Also we know that S'p j < Sq^t by the definition of /. In sum, we showed that any 
request that forced SSF-W to do a broadcast during [ti — Sq^kC(*c, ti] have a slack no bigger than Sq^k and 
a delay factor no smaller than a*, which is a contradiction of the definition of ti. □ 
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